<?php
	/**
	 * This is a quick-and-dirty draft QForm object to do Create, Edit, and Delete functionality
	 * of the MantisCustomFieldTable class.  It uses the code-generated
	 * MantisCustomFieldTableMetaControl class, which has meta-methods to help with
	 * easily creating/defining controls to modify the fields of a MantisCustomFieldTable columns.
	 *
	 * Any display customizations and presentation-tier logic can be implemented
	 * here by overriding existing or implementing new methods, properties and variables.
	 * 
	 * NOTE: This file is overwritten on any code regenerations.  If you want to make
	 * permanent changes, it is STRONGLY RECOMMENDED to move both mantis_custom_field_table_edit.php AND
	 * mantis_custom_field_table_edit.tpl.php out of this Form Drafts directory.
	 *
	 * @package My QCubed Application
	 * @subpackage FormBaseObjects
	 */
	abstract class MantisCustomFieldTableEditFormBase extends QForm {
		// Local instance of the MantisCustomFieldTableMetaControl
		/**
		 * @var MantisCustomFieldTableMetaControlGen mctMantisCustomFieldTable
		 */
		protected $mctMantisCustomFieldTable;

		// Controls for MantisCustomFieldTable's Data Fields
		protected $lblId;
		protected $txtName;
		protected $txtType;
		protected $txtPossibleValues;
		protected $txtDefaultValue;
		protected $txtValidRegexp;
		protected $txtAccessLevelR;
		protected $txtAccessLevelRw;
		protected $txtLengthMin;
		protected $txtLengthMax;
		protected $txtRequireReport;
		protected $txtRequireUpdate;
		protected $txtDisplayReport;
		protected $txtDisplayUpdate;
		protected $txtRequireResolved;
		protected $txtDisplayResolved;
		protected $txtDisplayClosed;
		protected $txtRequireClosed;
		protected $txtFilterBy;

		// Other ListBoxes (if applicable) via Unique ReverseReferences and ManyToMany References

		// Other Controls
		/**
		 * @var QButton Save
		 */
		protected $btnSave;
		/**
		 * @var QButton Delete
		 */
		protected $btnDelete;
		/**
		 * @var QButton Cancel
		 */
		protected $btnCancel;

		// Create QForm Event Handlers as Needed

//		protected function Form_Exit() {}
//		protected function Form_Load() {}
//		protected function Form_PreRender() {}

		protected function Form_Run() {
			parent::Form_Run();
		}

		protected function Form_Create() {
			parent::Form_Create();

			// Use the CreateFromPathInfo shortcut (this can also be done manually using the MantisCustomFieldTableMetaControl constructor)
			// MAKE SURE we specify "$this" as the MetaControl's (and thus all subsequent controls') parent
			$this->mctMantisCustomFieldTable = MantisCustomFieldTableMetaControl::CreateFromPathInfo($this);

			// Call MetaControl's methods to create qcontrols based on MantisCustomFieldTable's data fields
			$this->lblId = $this->mctMantisCustomFieldTable->lblId_Create();
			$this->txtName = $this->mctMantisCustomFieldTable->txtName_Create();
			$this->txtType = $this->mctMantisCustomFieldTable->txtType_Create();
			$this->txtPossibleValues = $this->mctMantisCustomFieldTable->txtPossibleValues_Create();
			$this->txtDefaultValue = $this->mctMantisCustomFieldTable->txtDefaultValue_Create();
			$this->txtValidRegexp = $this->mctMantisCustomFieldTable->txtValidRegexp_Create();
			$this->txtAccessLevelR = $this->mctMantisCustomFieldTable->txtAccessLevelR_Create();
			$this->txtAccessLevelRw = $this->mctMantisCustomFieldTable->txtAccessLevelRw_Create();
			$this->txtLengthMin = $this->mctMantisCustomFieldTable->txtLengthMin_Create();
			$this->txtLengthMax = $this->mctMantisCustomFieldTable->txtLengthMax_Create();
			$this->txtRequireReport = $this->mctMantisCustomFieldTable->txtRequireReport_Create();
			$this->txtRequireUpdate = $this->mctMantisCustomFieldTable->txtRequireUpdate_Create();
			$this->txtDisplayReport = $this->mctMantisCustomFieldTable->txtDisplayReport_Create();
			$this->txtDisplayUpdate = $this->mctMantisCustomFieldTable->txtDisplayUpdate_Create();
			$this->txtRequireResolved = $this->mctMantisCustomFieldTable->txtRequireResolved_Create();
			$this->txtDisplayResolved = $this->mctMantisCustomFieldTable->txtDisplayResolved_Create();
			$this->txtDisplayClosed = $this->mctMantisCustomFieldTable->txtDisplayClosed_Create();
			$this->txtRequireClosed = $this->mctMantisCustomFieldTable->txtRequireClosed_Create();
			$this->txtFilterBy = $this->mctMantisCustomFieldTable->txtFilterBy_Create();

			// Create Buttons and Actions on this Form
			$this->btnSave = new QButton($this);
			$this->btnSave->Text = QApplication::Translate('Save');
			$this->btnSave->AddAction(new QClickEvent(), new QAjaxAction('btnSave_Click'));
			$this->btnSave->CausesValidation = true;

			$this->btnCancel = new QButton($this);
			$this->btnCancel->Text = QApplication::Translate('Cancel');
			$this->btnCancel->AddAction(new QClickEvent(), new QAjaxAction('btnCancel_Click'));

			$this->btnDelete = new QButton($this);
			$this->btnDelete->Text = QApplication::Translate('Delete');
			$this->btnDelete->AddAction(new QClickEvent(), new QConfirmAction(sprintf(QApplication::Translate('Are you SURE you want to DELETE this %s?'), QApplication::Translate('MantisCustomFieldTable'))));
			$this->btnDelete->AddAction(new QClickEvent(), new QAjaxAction('btnDelete_Click'));
			$this->btnDelete->Visible = $this->mctMantisCustomFieldTable->EditMode;
		}

		/**
		 * This Form_Validate event handler allows you to specify any custom Form Validation rules.
		 * It will also Blink() on all invalid controls, as well as Focus() on the top-most invalid control.
		 */
		protected function Form_Validate() {
			// By default, we report the result of validation from the parent
			$blnToReturn = parent::Form_Validate();

			// Custom Validation Rules
			// TODO: Be sure to set $blnToReturn to false if any custom validation fails!
			

			$blnFocused = false;
			foreach ($this->GetErrorControls() as $objControl) {
				// Set Focus to the top-most invalid control
				if (!$blnFocused) {
					$objControl->Focus();
					$blnFocused = true;
				}

				// Blink on ALL invalid controls
				$objControl->Blink();
			}

			return $blnToReturn;
		}

		// Button Event Handlers

		protected function btnSave_Click($strFormId, $strControlId, $strParameter) {
			// Delegate "Save" processing to the MantisCustomFieldTableMetaControl
			$this->mctMantisCustomFieldTable->SaveMantisCustomFieldTable();
			$this->RedirectToListPage();
		}

		protected function btnDelete_Click($strFormId, $strControlId, $strParameter) {
			// Delegate "Delete" processing to the MantisCustomFieldTableMetaControl
			$this->mctMantisCustomFieldTable->DeleteMantisCustomFieldTable();
			$this->RedirectToListPage();
		}

		protected function btnCancel_Click($strFormId, $strControlId, $strParameter) {
			$this->RedirectToListPage();
		}

		// Other Methods

		protected function RedirectToListPage() {
			QApplication::Redirect(__VIRTUAL_DIRECTORY__ . __FORM_DRAFTS__ . '/mantis_custom_field_table_list.php');
		}
	}
?>
